<template>
  <div class="login" @click='$refs.verify.show = false'>
    <Row @keydown.enter.native="submitLogin" class="flex">
      <Col style="width: 368px">
      <Header />
      <Row style="flex-direction: column;">

        <Form ref="usernameLoginForm" :model="form" :rules="rules" class="form">
          <FormItem prop="username">
            <Input v-model="form.username" prefix="ios-contact" size="large" clearable placeholder="请输入用户名"
              autocomplete="off" />
          </FormItem>
          <FormItem prop="password">
            <Input type="password" v-model="form.password" prefix="ios-lock" size="large" password placeholder="请输入密码"
              autocomplete="off" />
          </FormItem>
        </Form>
        <Row>
          <Button class="login-btn" type="primary" size="large" :loading="loading" @click="submitLogin" long>
            <span v-if="!loading">{{ $t("login") }}</span>
            <span v-else>{{ $t("logining") }}</span>
          </Button>
        </Row>

      </Row>
      <!-- 拼图验证码 -->
      <verify ref="verify" class="verify-con" verifyType="LOGIN" @change="verifyChange"></verify>
      <Footer />
      </Col>
      <!-- <LangSwitch /> -->
    </Row>
  </div>
</template>

<script>
  import {
    login,
    userInfo
  } from "@/api/index";
  import Cookies from "js-cookie";
  import Header from "@/views/main-components/header";
  import Footer from "@/views/main-components/footer";
  import LangSwitch from "@/views/main-components/lang-switch";
  import util from "@/libs/util.js";
  import verify from "@/views/my-components/verify";

  export default {
    components: {
      LangSwitch,
      Header,
      Footer,
      verify
    },
    data() {
      return {
        loading: false, // 加载状态
        form: {
          // 表单数据
          username: "",
          password: "",
          mobile: "",
          code: "",
        },
        rules: {
          // 验证规则
          username: [{
            required: true,
            message: "账号不能为空",
            trigger: "blur",
          }, ],
          password: [{
            required: true,
            message: "密码不能为空",
            trigger: "blur",
          }, ],
        },
      };
    },
    methods: {
      afterLogin(res) {
        console.log(res)
        // 登录成功后处理
        let accessToken = res.result.accessToken;
        let refreshToken = res.result.refreshToken;
        let userEnums=res.result.userEnums
        this.setStore("accessToken", accessToken);
        this.setStore("refreshToken", refreshToken);
        this.setStore("userEnums",userEnums)
        this.$store.commit("clearAllTags");
        // 获取用户信息
        userInfo().then((res) => {
          if (res.success) {
            // 加载菜单
            Cookies.set("userInfoManager", JSON.stringify(res.result));
            this.$store.commit("setAvatarPath", res.result.avatar);
            util.initRouter(this);
            let data = res.result.roles
            let dls = data.filter((item) => {
              return item.name === '代理商'
            })
            // if (dls.length > 0) {
            //   this.$router.push({
            //     path: "memberList",
            //   });
            // } else {
              this.$router.push({
                name: "home_index",
              });
            // }
          } else {
            this.loading = false;
          }
        });
      },
      submitLogin() {
        // 登录操作
        this.$refs.usernameLoginForm.validate((valid) => {
          if (valid) {
            this.$refs.verify.init();
          }
        });
      },
      verifyChange(con) {
        // 拼图验证码回显
        if (!con.status) return;

        this.loading = true;
        login({
            username: this.form.username,
            password: this.md5(this.form.password),
          })
          .then((res) => {
            if (res && res.success) {
              this.afterLogin(res);
            } else {
              this.loading = false;
            }
          })
          .catch(() => {
            this.loading = false;
          });
        this.$refs.verify.show = false;
      },
    },
  };
</script>

<style lang="scss" scoped>
  .login {
    height: 100%;
    background: url("../assets/background.png") no-repeat;
    background-color: #f0f2f5;
    display: flex;
    background-size: cover;
    align-items: center;
    justify-content: center;


    .verify-con {
      position: absolute;
      top: 150px;
      z-index: 10;
      left: 20px;
    }

    .form {
      padding-top: 1vh;

    }

    .login-btn {
      background: linear-gradient(135deg, $theme_color 0%, $warning_color 100%);
      height: 40px;
      cursor: pointer;
      border-radius: 4px;
      display: flex;
      align-items: center;
      justify-content: center;
      font-size: 16px;
      color: #fff;
      width: 100%;
      text-align: center;
      transition: 0.35s;
    }

    .login-btn:hover {
      opacity: .9;
      border-radius: 10px;
    }

  }

  .flex {
    justify-content: center;
  }
</style>
